﻿using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;
using System.Web.UI;
using System.Web.UI.WebControls;
using System.Data;
using Generico.Coneccion;

namespace Administracion.Administracion
{
    public partial class Formulario_web13 : System.Web.UI.Page
    {
        protected void Page_Load(object sender, EventArgs e)
        {
            if (!this.IsPostBack)
            {
                CargarLista();
                if (lstInfo.Items.Count >= 1)
                {
                    this.lstInfo.SelectedIndex = 0;
                    cargardatos(Convert.ToInt32(lstInfo.SelectedValue));
                }
                Habilitar(true);
            }
        }

        protected void btnAgregar_Click(object sender, EventArgs e)
        {
            Limpiar();
            Visualizar(true);
            Habilitar(false);
            this.Session.Add("Transaccion", "A");
        }

        protected void btnEliminar_Click(object sender, EventArgs e)
        {

        }

        protected void btnModificar_Click(object sender, EventArgs e)
        {
            Visualizar(true);
            Habilitar(false);
            this.Session.Add("Transaccion", "M");
        }

        protected void btnAceptar_Click(object sender, EventArgs e)
        {
            string varTransaccion = Session["Transaccion"].ToString();

            var cn = new ClsConeccion();
            cn.Abrir();
            if (varTransaccion == "A")
            {
                cn.EjecutarSql("Insert Into SubTemas values ('" + txtSubTema.Text + "')");
                CargarLista();
            }

            if (varTransaccion == "M")
            {
                cn.EjecutarSql("Update SubTemas Set Temas = '" + txtSubTema.Text + "' where idSubTemas = " + txtId.Text);
            }
            cn.Cerrar();
            Response.Write("<script> alert('Se ha guardado correctamente');</script>");
            Visualizar(false);
            Habilitar(true);
        }

        protected void btnCancelar_Click(object sender, EventArgs e)
        {
            Limpiar();
            Visualizar(false);
            Habilitar(true);
        }
        private void cargardatos(int valor)
        {
            var cn = new ClsConeccion();
            cn.Abrir();
            var rd = cn.EjecutarSqlDataReader("Select * From SubTemas where idSubTemas = " + valor.ToString());
            while (rd.Read())
            {
                txtId.Text = rd["idSubTemas"].ToString();
                this.txtSubTema.Text = rd["SubTemas"].ToString();
               // chkVisibilidad.Checked = Convert.IsDBNull(rd["Inactivo"]) ? false : Convert.ToBoolean(rd["Inactivo"]);

            }
            rd.Close();
            cn.Cerrar();
        }
        private void Limpiar()
        {
            txtId.Text = "";
            txtSubTema.Text = "";

        }
        private void Visualizar(bool visible)
        {
            btnAceptar.Visible = visible;
            btnCancelar.Visible = visible;
        }
        private void Habilitar(bool habilitado)
        {
            btnModificar.Enabled = habilitado;
            btnAgregar.Enabled = habilitado;
            btnEliminar.Enabled = habilitado;
            txtSubTema.Enabled = !habilitado;
            chkVisibilidad.Enabled = !habilitado;

        }
        private void CargarLista()
        {
            var cn = new ClsConeccion();
            cn.Abrir();
            var rd = cn.EjecutarSqlDataReader("Select * From SubTemas");
            var dt = new DataTable();
            dt.Load(rd);
            cn.Cerrar();
            this.lstInfo.DataSource = dt;
            this.lstInfo.DataTextField = "SubTemas";
            this.lstInfo.DataValueField = "idSubTemas";
            this.lstInfo.DataBind();
        }
        protected void lstInfo_SelectedIndexChanged1(object sender, EventArgs e)
        {
            if (lstInfo.SelectedValue != String.Empty)
            {
                cargardatos(Convert.ToInt32(lstInfo.SelectedValue));
            }
        }
    }
}
